{% extends 'layout/basic.html' %}
{% load static %}
{% block title %}用户注册{% endblock %}


{% block css %}
    <link rel="stylesheet" href="{% static 'css/account.css' %}">
    <style>
    .error-msg{
        color: red;
        position: absolute;
    }
    </style>
{% endblock %}


{% block content %}
    <div class="account">
        <div class="title">用户注册</div>
        <form id="regForm" method="POST" novalidate>
            {% csrf_token %}
            {% for field in form %}
                {% if field.name == 'code' %}
                    <div class="form-group">
                        <label for="{{ field.id_for_label }}">{{ field.label }}</label>
                        <div class="row">
                            <div class="col-xs-7">
                                {{ field }}
                                <span class="error-msg"></span>
                            </div>
                            <div class="col-xs-5">
                                <input id="btnSms" type="button" class="btn btn-default" value="点击获取验证码">
                            </div>
                        </div>
                    </div>
                {% else %}
                    <div class="form-group">
                        <label for="{{ field.id_for_label }}">{{ field.label }}</label>
                        {{ field }}
                        <span class="error-msg"></span>
                    </div>
                {% endif %}
            {% endfor %}

            <div class="row">
                <div class="col-xs-3">
                    <input id="btnSubmit" type="button" class="btn btn-primary" value="注  册"/>
                </div>
            </div>
        </form>
    </div>
{% endblock %}


{% block js %}
    <script>
        //页面框架加载完成之后，自动执行的函数
        $(function (){
            bindClickBtnSms();
            bindClickSubmit();
        });
        /*
        点击提交（注册）
        */
        function bindClickSubmit(){
            $('#btnSubmit').click(function (){
                $('.error-msg').empty();
                //收集表单中的数据
                console.log($('#regForm').serialize());//包含所有字段的数据 + 携带csrf_token

                //将数据发送Ajax请求到后台
                $.ajax({
                    url: "{% url 'register' %}",
                    type: 'POST',
                    data:$('#regForm').serialize(),
                    dataType:"JSON",
                    success:function (res){
                        console.log(res);
                        if(res.status){
                            location.href = res.data;
                        }else {
                            $.each(res.error,function (key,value) {
                                $('#id_'+key).next().text(value[0])
                            })
                        }

                    }
                })
            })
        }
        /*
        点击获取验证码的按钮绑定事件
        */
        function bindClickBtnSms(){
            $('#btnSms').click(function (){
                $('.error-msg').empty();
                //获取用户输入的手机号
                //找到数据框的ID，根据ID获取值，如何找到手机号的ID？
                var mobilePhone = $('#id_phone').val();
                console.log(mobilePhone);
                //发送Ajax请求
                $.ajax({
                    {#url:'/send/sms/',   // http://www.xxx.com/index/?k1=123&k2=234#}
                    url:"{% url 'send_sms' %}",   // http://www.xxx.com/index/?k1=123&k2=234
                    type:'GET',
                    data:{phone:mobilePhone,tpl:'register'},
                    dataType:'JSON',
                    success:function (res){
                        //Ajax请求发送之后自动执行的函数,res就是后端返回的值
                        if (res.status){
                            console.log('发送成功，倒计时');
                            sendSmsRemind();
                        }else {
                            console.log(res)
                            $.each(res.error,function (key,value) {
                                $('#id_'+key).next().text(value[0])
                            })
                        }
                    }
                })

            })
        }
        /*
        倒计时
         */
        function sendSmsRemind() {
            var $smsBtn = $('#btnSms');
            $smsBtn.prop('disabled', true); // 禁用
            var time = 60;
            var remind = setInterval(function () {
                $smsBtn.val(time + '秒重新发送');
                time = time - 1;
                if (time < 1) {
                    clearInterval(remind);
                    $smsBtn.val('点击获取验证码').prop('disabled', false);
                }
            }, 1000)

        }
    </script>

{% endblock %}